package cn.tedu.csmall.product.service.impl;

import cn.tedu.csmall.product.ex.ServiceException;
import cn.tedu.csmall.product.mapper.AttributeTemplateMapper;
import cn.tedu.csmall.product.pojo.dto.AttributeTemplateAddNewDTO;
import cn.tedu.csmall.product.pojo.entity.AttributeTemplate;
import cn.tedu.csmall.product.pojo.vo.AlbumStandardVO;
import cn.tedu.csmall.product.pojo.vo.AttributeTemplateStandardVO;
import cn.tedu.csmall.product.service.IAttributeTemplateService;
import cn.tedu.csmall.product.web.ServiceCode;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
@Slf4j
public class AttributeTemplateServiceImpl implements IAttributeTemplateService {
    @Autowired
    AttributeTemplateMapper attributeTemplateMapper;

    @Override
    public void addNew(AttributeTemplateAddNewDTO attributeTemplateAddNewDTO) {
        String name = attributeTemplateAddNewDTO.getName();
        int count = attributeTemplateMapper.countByName(name);
        if(count != 0){
            throw new ServiceException(ServiceCode.ERR_CONFLICT,"添加属性模板失败,尝试添加的属性模板已被占用!");
        }
        AttributeTemplate attributeTemplate = new AttributeTemplate();
        BeanUtils.copyProperties(attributeTemplateAddNewDTO,attributeTemplate);
        attributeTemplateMapper.insert(attributeTemplate);
    }

    @Override
    public void delete(Long id){
        log.debug("开始处理[删除属性模板]的业务,参数:{}",id);
        AttributeTemplateStandardVO queryResult = attributeTemplateMapper.getStandardById(id);
        if(queryResult == null){
            String message = "删除失败,属性模板名不存在";
            log.debug(message);
            throw new ServiceException(ServiceCode.ERR_NOT_FOUND,message);
        }
        log.debug("开始删除......");
        attributeTemplateMapper.deleteById(id);
        log.debug("删除失败!");

    }

}
